草庐IT

java - AsyncTask 和上下文

全部标签

go - 如何测试实现 gorilla 上下文的函数

我写了一个将数据保存到redis数据库服务器的函数。挑战是我想测试这些功能,但不知道如何测试。我只是以某种方式开始函数packagesessrage/**Savedataintoredisdatabase.Inthecommoncase,*thedatawillbeonlyvalidduringarequest.Use*hashdatatypeinredis.*/import("../context""github.com/garyburd/redigo/redis""net/http")const(protocolstring="tcp"portstring=":6379")func

go - 将上下文传递给子目录

我有一个用于应用程序上下文的Context结构。ConfigureRouter函数接收上下文作为参数并设置全局变量c以便同一文件中的中间件可以使用它。varc*core.ContextfuncConfigureRouter(ctx*core.Context,router*httprouter.Router){c=ctx//makecontextavailableinallmiddlewarerouter.POST("/v1/tokens/create",token.Create)//usinghttprouter}上面列出的一个路由调用了token.Create(来自作为子目录的tok

使用 http.server 转到上下文

为了测试我正在编写的服务器,我希望能够在测试框架中启动和停止它。为此,我希望我可以整合thecontextpackage在http.Server结构中。我希望能够在调用Done函数并且ctx.Done()channel返回某些内容时停止服务器。我想做的就是修改thehttp.Server.Serve()method,在for循环的每次迭代中接受context.Context并检查它是否完成,如下所示:func(srv*server)Serve(ctxcontext.Context,lnet.Listener)error{deferl.Close()vartempDelaytime.Du

go - 如何设置 HTTP Post 实体,如 Java 的方法 HttpPost.setEntity

我是一名新的golang程序员。在java中,使用HTTP.setEntity()方法很容易设置。但在golang中,我有测试服务器的方式来设置它,但我们的服务器仍然缺少接收实体数据。这是代码:funcbathPostDefects(){url:="http://127.0.0.1/edit"varjsonStr=[]byte(`{"key":"abc","id":"110175653","resolve":2,"online_time":"2016-7-22","priority":1,"comment":"something.."}`)req,err:=http.NewReques

java - 我将如何在 Java 中实现 Go 的无缓冲 channel ?

Go同时提供unbufferedandbufferedchannels用于goroutines(线程)之间的通信。是straightforward在Java中将缓冲channel实现为有界缓冲区。Go的无缓冲channel要求一个协程在另一个协程接收时发送。任何人都可以向我解释如何在Java中实现它吗? 最佳答案 在Java中你可以使用SynchronousQueue,Java8的源代码在这里http://grepcode.com/file/repository.grepcode.com/java/root/jdk/openjdk/

redirect - 重定向的上下文超时而不是使用客户端超时?

我使用显式http.Client.Timeout从客户端执行HTTP请求client:=http.Client{Timeout:timeout,//5seconds}httpResponse,err:=client.Do(httpRequest)但是这个客户端会执行一系列重定向(我不确定有多少)。据我了解,每次重定向都会重新开始超时,因此5秒的超时将为five-seconds*num-of-redirects。是否可以在context.Context中传递超时?ctx,_:=context.WithTimeout(context.Background(),5*time.Second)/

GoRoutines 并将结构传递给原始上下文

我有一个配置,它定义了一些实例(SomeConfigItems),每个实例都创建了一个thing()。那个东西是一个包含的包返回的结构,其中包含一个Price(float64)和一个嵌套结构。嵌套结构维护了一个交易图。问题是我能够遍历thing.Streams.Trades并从我的main()的for{}循环中实时查看所有交易。我看不到更新的东西。价格,即使它有时在处理程序中设置。我很难理解嵌套结构如何包含数据但不包含价格。我觉得好像我缺少一些关于范围、goroutines或可能是新对象实例化指针的东西。如有任何帮助,我将不胜感激,同时我会继续阅读。我已将代码缩减为看起来相关的内容。m

java - 如何使用 JNA 为具有多个返回值的 go 函数编写接口(interface)

我正在尝试导出一些Go函数并在Java中调用它们,使用JNA,但我不知道如何在Java中为具有多个返回值的Go函数定义接口(interface)。假设Go函数是://exportgenerateKeysfuncgenerateKeys()(privateKey,publicKey[]byte){return.....}返回值有两项,但在Java中,只允许有一项返回值。我能做什么? 最佳答案 cgo为多个返回值创建专用的C结构,并将各个返回值作为结构元素。在您的示例中,cgo将生成/*ReturntypeforgenerateKeys

go - 单值上下文中的多值选择.Text()

这个问题在这里已经有了答案:Multiplevaluesinsingle-valuecontext(6个答案)关闭4年前。编译时出现以下错误单值上下文中的多值选择.Text()varselection*agouti.Selections1:=a.page.FirstByXPath(`//*[@id="name"]`)selection=s1tmp_address=selection.Text()//ErrorisoccurringatthisLine.请帮助解决这个问题。

go - 如何在保留原始请求上下文的值的同时将上下文传递给 r.WithContext?

问题陈述我想将HTTP请求的生命周期与在Web应用程序范围之外创建的上下文相关联。因此,我编写了以下中间件(使用github.com/go-chi/chi):funcBindContext(ccontext.Context)func(http.Handler)http.Handler{returnfunc(hhttp.Handler)http.Handler{returnhttp.HandlerFunc(func(whttp.ResponseWriter,r*http.Request){h.ServeHTTP(w,r.WithContext(c))})}}中间件用于以下最小测试用例:p